1

10.

## WHAT IS CLAIMED IS:

| 1 | 1. A method for loading pixels into a temporary memory, comprising:                             |
|---|-------------------------------------------------------------------------------------------------|
| 2 | loading a block of pixels into said temporary memory;                                           |
| 3 | loading a staging memory with pixels for updating said block of pixels, by                      |
| 4 | rearranging said pixels so that an update group of pixels can be accessed in parallel from said |
| 5 | staging memory;                                                                                 |
| 6 | updating said block of pixels in said temporary memory with an update group                     |
| 7 | of pixels from said staging memory in parallel.                                                 |
| 1 | 2. The method of claim 1 wherein said temporary memory is connected                             |
| 2 | to a processing unit for comparing said block of pixels to a second block of pixels.            |
| 1 | 3. The method of claim 2 wherein said temporary memory is a two-                                |
| 2 | dimensional shift register, and wherein said update group of pixels corresponds to a shifted    |
| 3 | row or column of said block of data.                                                            |
| 1 | 4. The method of claim 2 wherein said processing unit performs a                                |
| 2 | comparison for a motion estimation algorithm.                                                   |
| 1 | 5. The method of claim 1 wherein said staging memory comprises banks                            |
| 2 | of memories, each bank providing a different one of said update group of pixels.                |
| 1 | 6. The method of claim 5 wherein said update group of pixels is a row or                        |
| 2 | column.                                                                                         |
| 1 | 7. The method of claim 1 further comprising providing a search pattern                          |
| 2 | that can be executed by loading said temporary memory, in a single cycle, with pixels to        |
| 3 | provide a next block to be searched.                                                            |
| 1 | 8. The method of claim 7 wherein said search pattern is a spiral search                         |
| 2 | pattern.                                                                                        |
| 1 | 9. The method of claim 1 wherein said rearranging of said pixels                                |
| 2 | comprises reordering said pixels in each row so that each pixels from a single column are       |
| 3 | spread across a plurality of columns so that they can be accessed in parallel.                  |

A method for loading pixels into a temporary memory, comprising:

loading a block of pixels into said temporary memory, said temporary memory

2

3

1

2

row or column of said block of data.

17.

connected to a processing unit for comparing said block of pixels to a second block of pixels.

The apparatus of claim 12 wherein said temporary memory is

| 1                                                                                                                                                                    | 18. The apparatus of claim 17 wherein said processing unit performs a                         |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| 2                                                                                                                                                                    | comparison for a motion estimation algorithm.                                                 |
| 1                                                                                                                                                                    | 19. An apparatus, comprising:                                                                 |
| 2                                                                                                                                                                    | a two dimensional shift register for storing a block of pixels;                               |
| 3                                                                                                                                                                    | a processing unit coupled to said two dimensional shift register, said                        |
| 4                                                                                                                                                                    | processing unit being configured to simultaneously compare each pixel in said block of pixels |
| 5                                                                                                                                                                    | with a reference block of pixels;                                                             |
| 6                                                                                                                                                                    | a plurality of memory banks for storing new pixels for updating said block of                 |
| 7                                                                                                                                                                    | pixels;                                                                                       |
| 8                                                                                                                                                                    | an address translator coupled to an input to said plurality of memory banks for               |
| <b>G</b> 9                                                                                                                                                           | rearranging said new pixels so that an update group of said new pixels can be accessed in     |
| 10                                                                                                                                                                   | parallel from said plurality of memory banks;                                                 |
| <u> </u>                                                                                                                                                             | an addressing unit for reordering a group of pixels accessed in parallel from                 |
| <b>1</b> 12                                                                                                                                                          | said plurality of memory banks to said two dimensional shift register, correcting for         |
| <b>1</b> 3                                                                                                                                                           | rearrangements made by said address translator to allow said new pixels to be accessed in     |
| 14                                                                                                                                                                   | parallel.                                                                                     |
| N.                                                                                                                                                                   |                                                                                               |
| 14 l<br>fa                                                                                                                                                           | 20. The apparatus of claim 19 further comprising:                                             |
| 14<br>11<br>11<br>12<br>13<br>13<br>13<br>13<br>13<br>13<br>13<br>13<br>14<br>14<br>14<br>15<br>15<br>15<br>15<br>15<br>15<br>15<br>15<br>15<br>15<br>15<br>15<br>15 | four buffers coupled to said two dimensional shift register for buffering new                 |
| <sup>1</sup> ± 3.                                                                                                                                                    | rows and columns of pixels to be shifted in from the left, right, top and bottom.             |